Method for securing digital content

ABSTRACT

A method for secure distribution of digital content to an untrusted environment, comprising the steps of: constructing a relatively trusted environment within the untrusted environment; constructing at least two digital inputs, the digital inputs are operable in order to reproduce the digital content; transferring digital media to the relatively trusted environment such that each of the inputs is transmitted via a different path, and combining the inputs in order to reproduce the digital content.

CROSS-REFERENCE TO RELATED APPLICATIONS

[0001] This application is related to and claims priority from U.S. Provisional Patent Application No. 60/2653,233, filed Jan. 23, 2001, the contents of which are hereby incorporated herein by reference in their entirety.

FIELD OF THE INVENTION

[0002] The present invention relates generally to the field of digital copyright protection. More specifically, the present invention deals with protection measures against illegal copying of digital audio and/or video.

BACKGROUND OF THE INVENTION

[0003] Illegal copying and distribution of multimedia digital content (audio and video) is prevalent in recent years, especially using the Internet. This illegal copying and distribution is an infringement of copyright protection laws and cause financial damages to the rightful owners of the digital content. It is therefore of great interest to find methods that would mitigate illegal copying and/or distribution of multimedia files without offending rightful usage.

[0004] Methods for usage rights enforcement of digital media are known. Some methods are desired to monitor digital copying of the digital content. For example, the system described in U.S. Pat. No. 6,115,533 authenticates an information signal prior to mass duplication of the signal by analyzing the signal to detect the presence or absence of a security signal therein, inserting a security signal into the information signal, and recording the modified signal only if no security signal was detected. U.S. Pat. No. 6,167,136 describes a method for securely storing analog or digital data on a data storage medium: an analog information signal is combined with a noise signal. The composite noise and information signal is encrypted with a key, which is derived from the noise signal. The encrypted composite signal is compressed and then recorded on the data storage medium along with an encrypted value of the key. The storage medium data is read, decompressed, and decrypted using a decryption key derived from the stored encrypted key. The data is then converted to an analog signal and combined with a noise correction signal derived from said key to eliminate the noise signal added to the analog information signal before storing the signal on the data storage medium.

[0005] Systems that run the MS-Windows™ operating system (OS) are equipped with the OS's Digital Rights Management (DRM) that supplies standard protection to digital content. The DRM consist of a set of filters, such as decryption, decoding and others that manipulate and channel the digital content to the screen card and/or sound card. Each filter exposes a set of virtual pins to connect to filters preceding and succeeding it. Each filter receives the digital content from its predecessor, manipulates it and transfers it to the next filter on the graph. While this traditional component may be viable solution for some digital content, it provides insufficient security to protect premium digital content. Since it's a layered component, at each layer a hacker can insert infringing software that connects between two filters (by the virtual pins) and redirect the digital content to the disk, A hacker may also substitute one of the OS supplied filters with his/hers own, hence hacking into the video path and again, redirect the digital content to the disk.

[0006] Other solutions wrap the digital content within encryption and business rules envelope, The rules are stored in a local database protected by encryption. This solution supplies better digital content management capabilities but lacks on the security side. If the local database is breached, the hacker can change the policy of the digital content. Furthermore the digital content encryption is easier to be breached in these types of solutions since it's not an integral part of the digital content player.

[0007] While these methods make illegal copying difficult, it is commonly believed that none of the existing methods provides sufficient security determined and competent opponents. Furthermore, once a certain protection method is cracked, the cracking tools and methods may become available to a large community via the Internet, thereby render the digital content effectively unprotected, and therefore an updateable solution is highly desireable.

[0008] It is foreseeable that as the availability of disc space and bandwidth for data communication will increase, illegal distribution of video and audio digital content will become prevalent unless effective counter-measures will be taken.

SUMMARY OF THE INVENTION

[0009] The present invention seeks to provide a novel method and system for securing the digital path of a digital video and/or audio and/or other digital content, in a manner that would increase substantially the difficulty of illegal copying of the digital content, The system is based on securing the digital path of the digital content bit steam, from its source, until it is finally rendered for display.

[0010] This security is basically achieved using one or more of the following methods and techniques:

[0011] Obscuring and or scrambling the digital content in the basic video/audio path, and forming one or more side path that contain the information that is needed for the reconstruction of the digital content, thereby effectively resisting possible copying along the path.

[0012] Split the bitstream into at least thereby effectively resist possible copying along the path.

[0013] Said splitting and scrambling is best performed as early as possible and recombined at the latest stage, essentially protecting the digital content at all vulnerable points in the path, for example, in the same module that decrypts a previously encrypted digital content.

[0014] There is also provided in accordance with a preferred embodiment of the present invention a method that further enhance the security and additionally provides an effective wade of between security level and ease of operation, based on trustworthiness credentials, said trustworthiness credential are based on information that is gathered using methods such as:

[0015] Geo-location: authentication support may be included to augment the system's ability to geo-locate the consumer, this may be necessary for business, legal, or other requirements (e.g. time zone authentication which may stem from other business or legal requirements). The level of geo-location authentication may be used as a trustworthiness credential.

[0016] Renderer reports; in order to monitor client ability to use external interfaces to access the digital content (e.g. a VCR on a video out interface), the renderer can report the type of video card, and as an option, insert a custom interference to the signal, which would not hamper viewing but prevent recording or will altogether prevent using the video out interface. An information gathering method (e.g. via the DDC —‘Display Data Channel’ monitor ‘Plug and Play’ communication protocol) could also be used to report the type of monitor used. The information gathered can be used in order to estimate trustworthiness credentials.

[0017] Authentication: the identity of the consumer can be authenticated. This can be achieved by compounding several methods, which could be a software/hardware key/challenge-response scheme, user and password-phrase, etc. The level of consumer identity authentication may be used as a trustworthiness credential.

[0018] There is also provided in accordance with a preferred embodiment of the present invention a system that, in order to further enhance the security of the system, incorporates one Or more of he following methods and techniques;

[0019] Path authentication: the system assures that the path is composed only of components that should participate in it, and that it was not subjected to tempering before and or during the passage of the digital content throughout the path.

[0020] Path consolidation: in cases where the path is implemented using connected software filters (“filter graph”) the secure path is composed of tamper resistant, consolidated filters, which use minimal external interfaces, thereby increasing the security of the system, The number of filters is maintained as low as possible. In cases where no other constraint exists, only one such filter is included (e.g. in cases where compatibility with existing components or with a standard interface is required, the system mazy be composed of tree filters: namely, source filter, video renderer and audio output or other combinations according to the compatibility requirements), The interface of each filter is preferably encrypted and/or secured using other methods.

[0021] In-path encryption/decryption: for encrypted digital content, encryption and decryption is done within the secure video path; hereby eliminating the chance of intercepting decrypted digital content outside the secure video path.

[0022] There is also provided in accordance with a preferred embodiment of the present invention methods that increase the overall security that are based on:

[0023] Automatic update support: The consumer side component should report, while communicating with the central server and/or the digital content servers, its update level, and either perform automatic updates as necessary (alternatively, the consumer could query the server for the current/necessary update version and initiate the update without reporting the current version) or prompt the consumer to initiate them, either way, the update level may be used as a trustworthiness credential when deciding to allow a certain transaction, as will be other security enhancing options.

[0024] Hardware security options: in addition to enhancing the security of software tamper resistance, dedicated hardware can be optionally used (perhaps as an optional, security credentials enhancing feature), in order to support geolocation and authentication.

[0025] According to a first aspect of the present invention there is provided a method for secure distribution of digital content to an untrusted environment, comprising the steps of: constructing a relatively trusted environment within the untrusted environment; constructing at least two digital inputs, the digital inputs are operable in order to reproduce the digital content; transferring digital media to the relatively trusted environment such that each of the inputs is transmitted via a different path, and combining the inputs in order to reproduce the digital content.

[0026] In a preferred embodiment of the present invention, the digital content is a document.

[0027] In another preferred embodiment of the present invention, the digital content is multimedia digital content.

[0028] In another preferred embodiment of the present invention, the multimedia digital content is an audio digital content.

[0029] In another preferred embodiment of the present invention, the multimedia digital content is a video digital content.

[0030] In another preferred embodiment of the present invention, the multimedia digital content consists of at least two different streams.

[0031] In another preferred embodiment of the present invention, at least one of the streams consists of video digital content.

[0032] In another preferred embodiment of the present invention, at least one of the streams consists of audio digital content.

[0033] In another preferred embodiment of the present invention, at least one of the streams consists of textual digital content.

[0034] In another preferred embodiment of the present invention, the untrusted environment comprises a consumer's computer.

[0035] In another preferred embodiment of the present invention, the relatively trusted environment comprises a software component.

[0036] In another preferred embodiment of the present invention, the software component is updateable.

[0037] In another preferred embodiment of the present invention, the software component comprises at least one tamper resistant software component.

[0038] In another preferred embodiment of the present invention, at least one of the software components is updateable.

[0039] In another preferred embodiment of the present invention, the relatively trusted environment comprises a hardware component.

[0040] In another preferred embodiment of the present invention, the hardware component comprises at least one tamper resistant hardware component.

[0041] In another preferred embodiment of the present invention, the relatively trusted environment comprises a firmware component.

[0042] In another preferred embodiment of the present intention, the firmware component is updateable.

[0043] In another preferred embodiment of the present invention, the firmware component comprises at least one tamper resistant firmware component.

[0044] In another preferred embodiment of the present invention, at least one of the tamper resistant firmware components is updateable.

[0045] In another preferred embodiment of the present invention, tie relatively trusted environment comprises at least two components.

[0046] In another preferred embodiment of the present invention, at least one of the components comprises a software component.

[0047] In another preferred embodiment of the present invention, the software component is updateable.

[0048] In another preferred embodiment of the present invention, the software component comprises at least one tamper resistant software component.

[0049] In another preferred embodiment of the present invention, at least one of the software components is updateable.

[0050] In another preferred embodiment of the present invention, at least one of the components comprises a hardware component.

[0051] In another preferred embodiment of the present invention, the hardware component comprises at least one tamper resistant hardware component.

[0052] In another preferred embodiment of the present invention, at least one of the components comprises a firmware component.

[0053] In another preferred embodiment of the present invention, the software firmware is updateable.

[0054] In another preferred embodiment of the present invention, the firmware component comprises at least one tamper resistant firmware component.

[0055] In another preferred embodiment of the present invention, at least one of the firmware components is updateable.

[0056] In another preferred embodiment of the present invention, at least one of the inputs comprise of a key.

[0057] In another preferred embodiment of the present invention, the key is a cryptographic key.

[0058] In another preferred embodiment of the present invention, the key is a scrambling key.

[0059] In another preferred embodiment of the present invention, at least one of the inputs comprises of a scrambled copy of the digital content, and ax least one other input comprise of the information needed for the reproduction.

[0060] In another preferred embodiment of the present invention, a group of at least two of the inputs comprise of a function of a scrambled copy of the digital content, and at least one other input comprise of the information needed for reconstruction.

[0061] In another preferred embodiment of the present invention, the reproduction results in an output that is identical to the digital content.

[0062] In another preferred embodiment of the present invention, the reproduction results in an output that is sufficiently similar to the digital content.

[0063] In another preferred embodiment of the present invention, a group of at least two of the inputs comprise of a function of the digital content.

[0064] In another preferred embodiment of the present invention, the function comprise of splitting the digital content to the inputs.

[0065] In another preferred embodiment of the present invention, the method comprise of using at least one updateable component.

[0066] In another preferred embodiment of the present invention, the updateable component is associated with a revision level identifier.

[0067] In another preferred embodiment of the present invention, the revision level identifier is a version number.

[0068] In another preferred embodiment of tee present invention, the revision level identifier is revision date.

[0069] In another preferred embodiment of the present invention, at least one aspect of operation of the underlying system depends on the revision level.

[0070] In another preferred embodiment of the present invention, at least some functionality of the underlying system is limited if the revision level does not belong to a specific set of revision levels.

[0071] In another preferred embodiment of die present invention, the limited functionality comprise of the ability to receive a set of digital content.

[0072] In another preferred embodiment of the present invention, the limited functionality comprise of the ability to receive a set of digital content in a specific format.

[0073] In another preferred embodiment of the present invention, the limited functionality comprise of the ability to receive a set of digital content in a specific method.

[0074] In another preferred embodiment of the present invention, the revision level is communicated to at least one other component of the underlying system by the updateable component.

[0075] In another preferred embodiment of the present invention, the communication is initiated by the updateable component.

[0076] In another preferred embodiment of the present invention, the communication is part of another communication that is part of the normal workflow of the underlying system.

[0077] In another preferred embodiment of the present invention, the communication is initiated by the other component of the underlying system.

[0078] In another preferred embodiment of the present invention, a component within the untrusted environment queries another component in the underlying system for revisioned version of the updateable component.

[0079] In another preferred embodiment of the present invention, transfer of the updateable component is performed automatically without intervention.

[0080] In another preferred embodiment of the present invention, transfer of the updateable component is initiated by approval.

[0081] In another preferred embodiment of the present invention, installation of the updateable component is performed automatically without intervention.

[0082] In another preferred embodiment of the present invention, installation of the updateable component is initiated by approval.

[0083] In another preferred embodiment of the present invention, the digital content is split into the separate inputs in a relatively trusted server, the server is operable to deliver the digital content to the relatively trusted environment in the form of the separate inputs.

[0084] In another preferred embodiment of the present invention, wherein the digital content arrive in the form of second separate inputs different from the first separate inputs to the relatively trusted server, the relatively busted server is operable to rearrange the digital content to the form of the first separate inputs.

[0085] In another preferred embodiment of the present invention, he digital content arrive in the form of the separate inputs to a server, the server is operable to deliver the digital content to the relatively trusted environment in the form of the separate inputs.

[0086] According to a second aspect of the present invention there is provided a method for secure distribution of digital content comprising the steps of gathering input from at least one source; producing trustworthiness credentials about the digital content's intended recipient environment based on the input; evaluate the intended recipient environment's trustworthiness credentials; determine a distribution policy according to the trustworthiness credentials evaluation, and performing decisions about the distribution according to the policy.

[0087] In a preferred embodiment of the present invention, the digital content is a document.

[0088] In another preferred embodiment of the present invention, the digital content is multimedia digital content.

[0089] In another preferred embodiment of the present invention, the multimedia digital content is an audio digital content.

[0090] In another preferred embodiment of the present invention, the multimedia digital content is a video digital content. In another preferred embodiment of the present invention, the multimedia digital content consists of at least two different streams.

[0091] In another preferred embodiment of the present invention, the credentials comprise geo-location information.

[0092] In another preferred embodiment of the present invention, the credentials comprise geo-location authentication level information.

[0093] In another preferred embodiment of the present invention, the credentials comprise authentication level information.

[0094] In another preferred embodiment of the present invention, the credentials comprise information gathered in the past.

[0095] In another preferred embodiment of the present invention, the credentials further comprise information gathered from analysis of the information gathered in the past.

[0096] In another preferred embodiment of the present invention, the information gathered in the past comprise of usage information.

[0097] In another preferred embodiment of the present invention, the credentials comprise of information about the environment into which the digital content is to be distributed.

[0098] In another preferred embodiment of the present invention, the information about the environment into which the digital content is to be distributed comprise of information about the software environment into which the digital content is to be distributed.

[0099] In another preferred embodiment of the present invention, information about the environment into which the digital content is to be distributed comprise of information about the hardware environment into which the digital content is to be distributed.

[0100] In another preferred embodiment of the present invention, the information about the hardware environment into which the digital content is to be distributed comprises information about the video output hardware in that environment.

[0101] In another preferred embodiment of the present invention, the information about the hardware environment into which the digital content is to be distributed comprises information about the sound output hardware in that environment.

[0102] In another preferred embodiment of the present invention, the information about the environment into which the digital content is to be distributed comprise of information about the firmware environment into which the digital content is to be distributed.

[0103] In another preferred embodiment of the present invention, the credentials comprise of reports from at least one relatively trusted component.

[0104] In another preferred embodiment of the present invention, at least one of the components resides in the consumer's computer.

[0105] In another preferred embodiment of the present invention, at least one of the components is connected to the consumer's computer.

[0106] In another preferred embodiment of the present invention, at least one of the components is a software component.

[0107] In another preferred embodiment of the present invention, at least one of the components is a firmware component.

[0108] In another preferred embodiment of the present invention, at least one of the components is a tamper resistant component.

[0109] In another preferred embodiment of the present invention, at least one of the components is a hardware component.

[0110] In another preferred embodiment of the present invention, at least one of the software components is updateable.

[0111] In another preferred embodiment of the present invention, at least one of the firmware components is updateable.

[0112] In another preferred embodiment of the present invention, the method comprise of using at least one updateable component.

[0113] In another preferred embodiment of the present invention, the updateable component is associated with a revision level identifier.

[0114] In another preferred embodiment of the present invention, the revision level identifier is a version number.

[0115] In another preferred embodiment of the present invention, the revision level identifier is revision date.

[0116] In another preferred embodiment of the present invention, at least one aspect of operation of the underlying system depends on the revision level.

[0117] In another preferred embodiment of the present invention, at least some functionality of the underlying system is limited if the revision level does not belong to a specific set of revision levels.

[0118] In another preferred embodiment of the present invention, the limited functionality comprise of the ability to receive a set of digital content.

[0119] In another preferred embodiment of the present invention, the limited functionality comprise of the ability to receive a set of digital content in a specific format.

[0120] In another preferred embodiment of the present invention, the limited functionality comprise of the ability to receive a set of digital content in a specific method.

[0121] In another preferred embodiment of the present invention, the revision level is communicated to at least one other component of the underlying system by the updateable component.

[0122] In another preferred embodiment of the present invention, the communication is initiated by the updateable component.

[0123] In another preferred embodiment of the present invention, the communication is part of another communication that is part of the normal workflow of the underlying system.

[0124] In another preferred embodiment of the present invention, the communication is initiated by the other component of the underlying system.

[0125] In another preferred embodiment of the present invention, a component within the untrusted environment queries another component in the underlying system for revisioned version of the updateable component.

[0126] In another preferred embodiment of the present invention, transfer of the updateable component is performed automatically without intervention.

[0127] In another preferred embodiment of the present invention, transfer of the updateable component is initiated by approval.

[0128] In another preferred embodiment of the present invention, installation of the updateable component is performed automatically without intervention.

[0129] In another preferred embodiment of the present invention, installation of the updateable component is initiated by approval.

[0130] In another preferred embodiment of the present invention, the credentials comprise of the revision level.

[0131] According to a third aspect of the present invention there is provided a method for secure distribution of digital content comprising the steps of: transferring digital media to an untrusted environment; using a relatively trusted environment within the untrusted environment operable to receive the digital content, the relatively trusted environment comprises of mechanisms to restrict tampering with the relatively trusted environment.

[0132] In a preferred embodiment of the present invention, the relatively trusted environment comprises at least two components.

[0133] In another preferred embodiment of the present invention, the components comprise at least one hardware component.

[0134] In another preferred embodiment of the present invention, the components comprise at least one software component.

[0135] In another preferred embodiment of the present invention, the components comprise at least one firmware component.

[0136] In another preferred embodiment of the present invention, the relatively trusted environment is a hardware component.

[0137] In another preferred embodiment of the present invention, the relatively trusted environment is a firmware component.

[0138] In another preferred embodiment of the present invention, the relatively trusted environment is a software component.

[0139] In another preferred embodiment of the present invention, the components comprise a watchdog component, the watchdog component is capable of monitoring other components of the relatively trusted environment.

[0140] In another preferred embodiment of the present invention, the monitoring comprise of authentication.

[0141] In another preferred embodiment of the present invention, the authentication comprise authentication of a certificate.

[0142] In another preferred embodiment of the present invention, the certificate is a cryptographic certificate.

[0143] In another preferred embodiment of the present invention, the authentication comprise authentication of the code of the component.

[0144] In another preferred embodiment of the present invention, the authentication of the code of the component comprise calculating a derivative of the code.

[0145] In another preferred embodiment of the present invention, the authentication of the code of the component comprises analysis of the potential operation of the code.

[0146] In another preferred embodiment of the present invention, the authentication comprise of a challenge-response method which comprise of a step in which the watchdog component queries the authenticated component issuing a input and further comprises of a later step in which the authenticated component issue an output to the watchdog the output dependent on the input and the authentication is based on the correctness of the output depending on the input.

[0147] In another preferred embodiment of the present invention, the monitoring comprises monitoring of the operation of the components.

[0148] In another preferred embodiment of the present invention, the monitoring of the operation of the components comprises monitoring of used interfaces.

[0149] In another preferred embodiment of the present invention, the monitoring of used interfaces comprise monitoring of used operating system calls.

[0150] In another preferred embodiment of the present invention, the monitoring of used interfaces comprises monitoring of file operations.

[0151] In another preferred embodiment of the present invention, the monitoring of used interfaces comprises monitoring of memory operations.

[0152] In another preferred embodiment of the present invention, the monitoring of used interfaces comprises monitoring of.

[0153] In another preferred embodiment of the present invention, the monitoring of used interfaces comprises monitoring of driver operations.

[0154] In another preferred embodiment of the present invention, the monitoring of used interfaces comprise monitoring of input operations.

[0155] In another preferred embodiment of the present invention, the monitoring of used interfaces comprise monitoring of output operations.

[0156] In another preferred embodiment of the present invention, the monitoring of used interfaces comprises monitoring of interfaces used by interfaced entities.

[0157] In another preferred embodiment of the present invention, the monitoring of used interfaces comprise monitoring of at least on of the following: interfaces used by interfaced entities, output operations, input operations, driver operations, communication operations, used operating system calls, file operations, memory operations and used interfaces.

[0158] In another preferred embodiment of the present invention, the relatively trusted environment comprises at least one updateable component.

[0159] In another preferred embodiment of the present invention, the updateable component is associated with a revision level identifier.

[0160] In another preferred embodiment of the present invention, the revision level identifier is a version number.

[0161] In another preferred embodiment of the present invention, the revision level identifier is revision date.

[0162] In another preferred embodiment of the present invention, at least one aspect of operation of the underlying system depends on the revision level.

[0163] In another preferred embodiment of the present invention, at least some functionality of the underlying system is limited if the revision level does not belong to a specific set of revision levels.

[0164] In another preferred embodiment of the present invention, to limited functionality comprise of the ability to receive a set of digital content.

[0165] In another preferred embodiment of the present invention, the limited functionality comprise of the ability to receive a set of digital content in a specific format.

[0166] In another preferred embodiment of the present invention, the limited functionality comprise of the ability to receive a set of digital content in a specific method.

[0167] In another preferred embodiment of the present invention, the revision level is communicated to at least one other component of the underlying system by the updateable component.

[0168] In another preferred embodiment of the present invention, the communication is initiated by the updateable component.

[0169] In another preferred embodiment of the present invention, the communication is part of another communication that is part of the normal workflow of the underlying system.

[0170] In another preferred embodiment of the present invention, the communication is initiated by the other component of the underlying system.

[0171] In another preferred embodiment of the present invention, a component within the untrusted environment queries another component in the underlying system for revisioned version of the updateable component.

[0172] In another preferred embodiment of the present invention, transfer of the updateable component is performed automatically without intervention.

[0173] In another preferred embodiment of the present invention, transfer of the updateable component is initiated by approval.

[0174] In another preferred embodiment of the present invention, installation of the updateable component is performed automatically without intervention.

[0175] In another preferred embodiment of the present invention, installation of the updateable component is initiated by approval.

[0176] In another preferred embodiment of the present invention, at least one of the components comprise of functionality to monitor at least one of its interfaces.

[0177] In another preferred embodiment of the present invention, the monitoring comprise of authentication.

[0178] In another preferred embodiment of the present invention, the authentication comprise authentication of a certificate.

[0179] In another preferred embodiment of the present invention, the certificate is a cryptographic certificate.

[0180] In another preferred embodiment of the present invention, the authentication comprise of a challenge-response method which comprise of a step in which the component queries the interfaced entity issuing a input and further comprises of a later step in which the interfaced entity issue an output to the component the output dependent on the input and the authentication is based on the correctness of the output depending on the input.

[0181] In another preferred embodiment of the present invention, the method comprise of functionality to monitor at least one of the interfaces used by the underlying system.

[0182] In another preferred embodiment of the present invention, the monitoring comprise of authentication.

[0183] In another preferred embodiment of the present invention, the authentication comprise authentication of a certificate.

[0184] In another preferred embodiment of the present invention, the certificate is a cryptographic certificate.

[0185] In another preferred embodiment of the present invention, the authentication comprise of a challenge-response method which comprise of a step in which the interfaced entity is queried by issuing a input and further comprises of a later step in which the interfaced entity issue back an output the output dependent on the input and the authentication is based on the correctness of the output depending on the input.

[0186] In another preferred embodiment of the present invention, the digital content arrives into the relatively trusted environment in a cryptographically encrypted format.

[0187] In another preferred embodiment of the present invention, information gathered from monitoring by at least one component is transferred to the watchdog component by the component.

[0188] In another preferred embodiment of the present invention, information gathered by the watchdog component is transferred as credentials information to a credentials based decision making mechanism.

[0189] In another preferred embodiment of the present invention, information gathered by the watchdog component is transferred as credentials information to a credentials based decision-making mechanism.

[0190] In another preferred embodiment of the present invention, the relatively trusted environment comprises mechanism to restrict coping of at least one of the outputs the relatively trusted environment generates.

[0191] In another preferred embodiment of the present invention, the output is part of an internal interface.

[0192] In another preferred embodiment of the present invention, the output is an external output.

[0193] In another preferred embodiment of the present invention, the external output is sound output.

[0194] In another preferred embodiment of the present invention, the external output is video output.

[0195] In another preferred embodiment of the present invention, die external output is analog output.

[0196] In another preferred embodiment of the present invention, the analog output is analog sound output.

[0197] In another preferred embodiment of the present invention, the analog output is analog video output.

[0198] In another preferred embodiment of the present invention, the mechanism to restrict coping comprise of altering the output in order to change a quality of the copy that is produced by the copying.

[0199] In another preferred embodiment of the present invention, the quality of the copy is the observable quality of the copy.

[0200] In another preferred embodiment of the present invention, the change of the quality is to adversely effect the quality.

[0201] In another preferred embodiment of the present invention, the copying is digital copying.

[0202] In another preferred embodiment of the present invention, the copying is non-digital copying.

[0203] In another preferred embodiment of the present invention, the copying is digital copying that involves a non-digital transition.

BRIEF DESCRIPTION OF THE DRAWINGS

[0204] The present invention will be understood and appreciated more fully from the following detailed description taken in conjunction with the appended drawings in which:

[0205]FIG. 1 is a simplified conceptual flow illustration of a method for copy protection for digital content, constructed and operative in accordance with a preferred embodiment of the present invention;

[0206]FIG. 2 is a simplified illustration of a system for copy protection, substantially similar to the system described in FIG. 1, operative in accordance with a preferred embodiment of the present invention;

[0207]FIG. 3 is a simplified description of macro-blocks scrambling, operative in accordance with a preferred embodiment of the present invention;

[0208]FIG. 4 is an illustration of a system for trustworthiness credential assignment, based on geo-location, authentication level and reports from software client, operative in accordance with a preferred embodiment of the present invention;

[0209]FIG. 5 is an illustration of a system, substantially similar to the system described in FIG. 2, operative in accordance with a preferred embodiment of the present invention, that further enhance the security of the path;

[0210]FIG. 6 is an illustration of a flowchart of a method, operative in accordance with a preferred embodiment of the present invention, that is used in order to locate infringing software components, such as “Trojan horses”, in the secure video path;

[0211]FIG. 7 is an illustration of security augmentation using hardware components, operative in accordance with a preferred embodiment of the present invention;

[0212]FIG. 8 is an illustration of a method for security improvements along the system lifecycle using automatic software updates, operative in accordance with a preferred embodiment of the present invention;

[0213]FIG. 9 is an illustration of another method for security improvements along the system lifecycle using automatic software updates, substantially similar to the method described in FIG. 8, operative in accordance with a preferred embodiment of the present invention, and

[0214]FIG. 10 is an illustration of a system, said system include a client that is substantially similar to the system illustrated in FIG. 2, where the source digital content and the digital content server reside in a secured zone, operative in accordance with a preferred embodiment of the present invention.

DETAILED DESCRIPTION OF PREFERRED EMBODIMENTS

[0215] The present invention seeks to provide a system and a method for digital content protection, in order to mitigate the hazards of copyright infringement. For a better understanding of the invention and to show how the same may be carried into effect, reference will now be made, purely by way of example, to the accompanying drawings.

[0216] With specific reference now to the drawings in detail, it is stressed that the particulars shown are by way of example and for purposes of illustrative discussion of the preferred embodiments of the present invention only, and are presented in the cause of providing what is believed to be the most useful and readily understood description of the principles and conceptual aspects of the invention. In this regard, no attempt is made to show structural details of the invention in more detail than is necessary for a fundamental understanding of the invention, the description taken with the drawings making apparent to those skilled in the art how the several forms of the invention may be embodied in practice. In the accompanying drawings:

[0217]FIG. 1 is a simplified conceptual flow illustration of a system for copy protection for digital content, constructed and operative in accordance with a preferred embodiment of the present invention. In the system of FIG. 1 parts of the basic stream 100 are scrambled, using a scrambling module 110, thereby substantially degrading the quality of the final digital content. The scrambling is preferably induced by a secret key 120. The information that is needed in order to reproduce the original digital content is included in a stream 130 that undergoes a different path. The digital content in main path 140 may be subjected to further processing 150. One component of the system, dubbed the de-scrambler 160, and is preferably a tamper-resistant component, receives information from both paths and performs the computations tat are required in order to reproduce the desired digital content 170.

[0218] Reference is now made to FIG. 2, which is a simplified illustration of a system, substantially similar to the system described in FIG. 1, operative in accordance with a preferred embodiment of the present invention. In the system of FIG. 2 the digital content in the basic path 200, is encrypted, using any standard encryption technique, in order to enhance the security level. The basic path enters a module 204, dubbed “source filter”. The decryption module 202 decrypts the digital content. The decrypted digital content is thereafter being decoded by the decoding sub-module 2102 (e.g., if the digital content is a video digital content, compressed/encoded using standard MPEO encoding, the decoder perform decoding/uncompressing, which results in a bitstream that represent sequence of frames and an audio stream), The scrambling sub-module 2104 thereafter scrambled the digital content (e.g., by changing the order of several macro-blocks in some of the frames). The resulted bitstream 240 represents a crippled digital content that can be properly rendered only by using side information (e.g., in cases where the digital content is a video digital content, and the scrambling consists of changing the order of some macro-blocks, the side information should reveal the correct order of the macro-blocks.) The renderer and descrambler module 260 reproduces the desired digital content, if the digital content is a video digital content, then the renderer produces the to-be displayed frames and uses the information in the side-path 230 in order to reconstruct the correct order of the macro-blocks. The resulted sequence of frames 270 is ready to be displayed by a standard display device. Note that, while scrambling is essentially a form of encryption, the scrambling retains much of the aspects of the decrypted digital content, thereby allowing most of the processing, that need to be done on decrypted digital content, to be performed in a more secure level.

[0219] Reference is now made to FIG. 3, which is a simplified description of macro-blocks scrambling, operative in accordance with a preferred embodiment of the present invention. The digital content 300 is divided to 12 macroblocks, which are scrambled by the scrambling module 3104, preferably using the side information 330. The scrambled digital content 340 can then be transferred in a more secure manner to the de-scrambling module 360, which reconstruct the correct order of the macro-blocks 370. The macroblocks can be the same macroblocks that are used for motion estimation in the standard MPEG format.

[0220] Turning now to FIG. 4, there is illustrated a system for trustworthiness credential assignment, based on geo-location, authentication level and reports from software client, operative in accordance with a preferred embodiment of the present invention. Resulting trustworthiness credentials may be used in order to determine what protective measures should be used, in order to achieve a satisfactory trade-off between ease-of-use and protection level and whether to allow the transaction (in the high risk cases). The geo-location subsystem 410 obtains information regarding the location of the user. Methods for obtaining geolocation data are described, e.g., in U.S. patent application Ser. No. 09/922,846. The geo-location data evaluation sub-system 414 uses the gathered data in order to assign credentials To the user. E.g., Coarse-grained geo-filtering can be used in order to determine whether the client comes from a state or a region that are notorious for not enforcing copyright protection laws. The authentication sub-system 420 is used to authenticate the user based on one or more of the known authentication methods (e.g., password-based or biometric-based authentication). The authentication data evaluation subsystem 424 receives data from the authentication subsystem 420, and preferably also from the geo-location subsystem 410: the geographical location of the user can be used in order to elevate the authenticity level, E.g., by checking the correlation between the stated address of the user and the gao-location data. Finally, another level of trustworthiness credentials can be established by knowing the software and hardware components that are used by the users in order to handle the digital content (e.g., digital content rendering, playing, displaying or recording). The components detection and reporting subsystem 430 detects components that are used for digital content handling and attempts to tamper with these components, If the said subsystem detects components tat can be used in order to record or copy the data in an unauthorized manner, or to assist such an operation, or if attempts to tamper with these components are detected, it reports about them to the component data evaluation subsystem 434, which may use this data in order to reduce the trustworthiness level of the user, and preferably perform additional operations as dictated by the situation. The trustworthiness credential assignment subsystem 440 uses the data from the geo-location data evaluation subsystem 414, the authentication data evaluation subsystem 424, and the components data evaluation subsystem 434 in order to assign trustworthiness credentials to the user. The policy determination subsystem 450 obtain the said trustworthiness credentials, and uses them in order to establish a more permissive policy if the user is trustworthy, and a less permissive policy if the user is suspected.

[0221] In other embodiments of the present invention the policy differentiates between different levels of: delivered quality, cost/ease of use for the consumer and/or the usage of certain protection mechanism in the digital content delivery and/or displaying process. The policy determination subsystem 450 may use rules that are stored in the data storage 460 and may store reports and other relevant information in the database 460, preferably in an encrypted format. The output of the policy determination subsystem 450 is used as an input to an authorization mechanism 470.

[0222] Turning now to FIG. 5, there is illustrated a system, substantially similar to the system described in FIG. 2, operative in accordance with a preferred embodiment of the present invention. The system further enhance the security of the path by incorporating methods for path authentication, path consolidation and, preferably, in-path decryption. In order to maintain path authentication, the system uses a software component 550, commonly referred as “watch-dog”, which assures that the path is composed only of components that should participate in it, and that it was not subjected to tampering before and or during the passage of the digital content through the path. The path consolidation mechanism is preferably used in cases where the path is implemented using connected software components, commonly dubbed “software filters”(in a “filter graph”). In this case, the secure path is composed of tamper resistant consolidated filters, which use minimal external interfaces, thereby increasing the security of the system. In a preferred embodiment of the present invention, the number of filters is maintained as low as possible. In cases where no other constraint exists, only one such filter is included. In cases where compatibility with existing components or with a standard are required, the system is preferably composed of three filters: namely, source filter, video renderer, and audio output. The interface of each filter is preferably encrypted and/or secured using other methods. For encrypted digital content decryption is done within the secure video path; thereby eliminating the chance of intercepting decrypted digital content outside the secure video path.

[0223] Note that interface in this context could be performed in many ways, e.g., messaging protocols, program context, shared memory or stack. Also note that internal interfaces (such as the memory used for making calculations) may be externally accessed in many computer environments. Hence, a filter may have more interfaces than its designers intended.

[0224] Turning now to FIG. 6, There is illustrated a flowchart of a method, operative in accordance with a preferred embodiment of the present invention, that is used in order to locate infringing software components, such as “Trojan horses”, in the secure video path. The flowchart depicts an algorithm that recursively looks for suspicious code in called components (i.e. code which may perform suspicious operations), effectively checking if such code exists within the components that may be called by the checked component.

[0225] The first step 605 selects the operating component to be checked, usually the first component in the path or filter graph. It is assigned a label—step 610—“to be checked”or “unchecked”, designating it as an unchecked component (in this case the root component). Next—step 615—a successful termination condition is checked—‘were all components designated for checking were checked and deemed OK?’. If the condition was satisfied—step 620—the path is deemed safe for digital content delivery and/or play. If the condition was not satisfied, the process continues—step 625—and a component is selected for checking (the identity of the component to be selected and the order of selection are not critical for the algorithm and dictates the sort of traversing of the underling call tree—DFS, BFS, etc. In a preferred embodiment of the present invention the mode of operation is DFS (Depth First Search) which dictates that the component to be selected should preferably be the last label component). Next—step 630—the component is checked for suspicious code. If such code exists in the component, a termination condition is met—step 635—and the path is deemed unsafe. If such code does not exist—step 640—the selected component is labeled “checked”. Next—step 645—the group of components called by the selected component is selected. The components in the selected group which are not labeled as “checked” are labeled “to be checked” —step 650. At this stage the test in step 615 is recursively repeated and the process recursively continues.

[0226] Note that this algorithm can be easily expanded by changing steps 605, 610, to start with a group of components to be checked (for example if several sources exist for a certain digital content, or if the software performing the related operations contains several independent components).

[0227] Methods for identifying suspicious components might be based, e.g., an tracing current component's ingoing and/or outgoing function calls, monitoring the system registry and utilizing the operating system services.

[0228] In another embodiment of the present invention, the software components are searched using one of the known node-graph searching method, where each software component is regarded as a node in the node-graph and each software component's import (ingoing) and export (outgoing) routines are treated as directed branch. Infringement suspects are identified by monitoring various operations such as file operations, memory operations, communication operations, I/O operations, driver operations and others or by reading the software components′ files (even while those components are running) and examining their digest or digital signature for authenticity and compliance with the security measurements.

[0229] In case of suspected infringement, the digital content streaming/downloading/playing/delivery may be stopped, and/or the suspected infringement information may be sent to a server that shall decide if to stop the digital content streaming/downloading/playing/delivery.

[0230] Turning now to FIG. 7, there is an illustration of security augmentation using hardware components 705, said hardware components can be a hardware implementation of either one of the components or sub-systems described above, or a combination of two or more of the aforementioned components and sub-systems.

[0231] Turning now to FIG. 8, there is an illustration of a method for security improvements along the system lifecycle using automatic software updates, operative in accordance with a preferred embodiment of the present invention. In step 801, the update server 805 inform client 815 about the needed update. In step 802 the client 815 sends a request for an update and in step 803 the update server 805 sends client 815 the required update.

[0232] Turning now to FIG. 9, there is an illustration of another method for security improvements along the system lifecycle using automatic software updates, substantially similar to the method described in FIG. 8, operative in accordance with a preferred embodiment of the present invention. In step 901 the update checking component 9152 in the client 915 ask update server 905 about needed updates on a regular base. In step 902 the update server 905 answer client 915 and in step 903 the update server 905 sends the required update to the client 915.

[0233] Turning now to FIG. 10, there is an illustration of a system, operative in accordance with a preferred embodiment of the present invention, said system include a client that is substantially similar to the system illustrated in FIG. 2, while the source digital content 1005 and the digital content server 1015 reside in a secured zone 1025. The source digital content is thereafter transferring via a secured path 1000, using a digital content server (e.g., a stream server) 1015. This way the entire path of the digital content, from the source to the player/display, is protected by encryption. In a preferred embodiment of the present invention, the digital content server pack the digital content, or parts of the digital content, in a “Vehicle format”, such as ASF, in order to increase the level of compatibility with existing software clients.

[0234] It is appreciated that one or more steps of any of the methods described herein may be implemented in a different order than that show, while not departing from the spirit and scope of the invention.

[0235] While the present invention may or may not have been described with reference to specific hardware or software, the present invention has been described in a manner sufficient to enable persons having ordinary skill in the art to readily adapt commercially available hardware and software as may be needed to reduce any of the embodiments of the present invention to practice without undue experimentation and using conventional techniques.

[0236] While the present invention has been described with reference to one or more specific embodiments, the description is intended to be illustrative of the invention as a whole and is not to be construed as limiting the invention to the embodiments shown. It is appreciated that various modifications may occur to those skilled in the art that, while not specifically shown herein, are nevertheless within the true spirit and scope of the invention. 

We claim:
 1. A method for secure distribution of digital content to an untrusted environment, comprising the steps of: constructing a relatively trusted environment within said untrusted environment; constructing at least two digital inputs, said digital inputs are operable in order to reproduce said digital content; transferring digital media to said relatively trusted environment such that each of said inputs is transmitted via a different path, and combining said inputs in order to reproduce said digital content.
 2. A method according to claim 1 wherein said digital content is a document.
 3. A method according to claim 2 wherein said digital content is multimedia digital content.
 4. A method according to claim 3 wherein said multimedia digital content is an audio digital content.
 5. A method according to claim 3 wherein said multimedia digital content is a video digital content.
 6. A method according to claim 3 wherein said multimedia digital content consists of at least two different streams.
 7. A method according to claim 6 wherein at least one of said different streams consists of video digital content.
 8. A method according to claim 6 wherein at least one of said different streams consists of audio digital content.
 9. A method according to claim 6 wherein at least one of said different streams consists of textual digital content.
 10. A method according to claim 1 wherein said untrusted environment comprise a consumer's computer.
 11. A method according to claim 1 wherein said relatively trusted environment comprise a software component.
 12. A method according to claim 11 wherein said software component is updateable.
 13. A method according to claim 11 wherein said software component comprise at least one tamper resistant software component.
 14. A method according to claim 13 wherein at least one of said software components is updateable.
 15. A method according to claim 1 wherein said relatively trusted environment comprise a hardware component.
 16. A method according to claim 15 wherein said hardware component comprise at least one tamper resistant hardware component.
 17. A method according to claim 1 wherein said relatively trusted environment comprise a firmware component.
 18. A method according to claim 17 wherein said firmware component is updateable.
 19. A method according to claim 17 wherein said firmware component comprise at least one tamper resistant firmware component.
 20. A method according to claim 19 wherein at least one of said tamper resistant firmware components is updateable.
 21. A method according to claim 1 wherein said relatively trusted environment comprise at least two components.
 22. A method according to claim 21 wherein at least one of said components comprises a software component.
 23. A method according to claim 22 wherein said software component is updateable.
 24. A method according to claim 22 wherein said software component comprise at least one tamper resistant software component.
 25. A method according to claim 24 wherein at least one of said software components is updateable.
 26. A method according to claim 21 wherein at least one of said components comprises a hardware component.
 27. A method according to claim 26 wherein said hardware component comprise at least one tamper resistant hardware component.
 28. A method according to claim 21 wherein at least one of said components comprises a firmware component.
 29. A method according to claim 28 wherein said software firmware is updateable.
 30. A method according to claim 28 wherein said firmware component comprise at least one tamper resistant firmware component.
 31. A method according to claim 30 wherein at least one of said firmware components is updateable.
 32. A method according to claim 1 wherein at least one of said inputs comprise of a key.
 33. A method according to claim 32 wherein said key is a cryptographic key.
 34. A method according to claim 32 wherein said key is a scrambling key.
 35. A method according to claim 1 wherein at least one of said inputs comprise of a scrambled copy of said digital content, and at least one other input comprise of the information needed for said reproduction.
 36. A method according to claim 1 wherein a group of at least two of said inputs comprise of a function of a scrambled copy of said digital content, and at least one other input comprise of the information needed for reconstruction.
 37. A method according to claim 1 wherein said reproduction results in an output which is identical to said digital content.
 38. A method according to claim 1 wherein said reproduction results in an output which is sufficiently similar to said digital content.
 39. A method according to claim 1 wherein a group of at least two of said inputs comprises of a function of said digital content.
 40. A method according to claim 39 wherein said function comprises of splitting said digital content to said inputs.
 41. A method according to claim 1 wherein said method comprise of using at least one updateable component.
 42. A method according to claim 41 wherein said updateable component is associated with a revision level identifier.
 43. A method according to claim 42 wherein said revision level identifier is a version number.
 44. A method according to claim 42 wherein said revision level identifier is revision date.
 45. A method according to claim 42 wherein at least one aspect of operation of the underlying system depends on said revision level.
 46. A method according to claim 45 wherein at least some functionality of the underlying system is limited if said revision level does not belong to a specific set of revision levels.
 47. A method according to claim 46 wherein said limited functionality comprise of the ability to receive a set of digital content.
 48. A method according to claim 46 wherein said limited functionality comprise of the ability to receive a set of digital content in a specific format.
 49. A method according to claim 46 wherein said limited functionality comprise of the ability to receive a set of digital content in a specific method.
 50. A method according to claim 42 wherein said revision level is communicated to at least one other component of the underlying system by said updateable component.
 51. A method according to claim 50 wherein said communication is initiated by said updateable component.
 52. A method according to claim 50 wherein said communication is part of another communication that is part of the normal workflow of the underlying system.
 53. A method according to claim 50 wherein said communication is initiated by said other component of the underlying system.
 54. A method according to claim 41 wherein a component within said untrusted environment queries another component in the underlying system for revisioned version of said updateable component.
 55. A method according to claim 41 wherein transfer of said updateable component is performed automatically without intervention.
 56. A method according to claim 41 wherein transfer of said updateable component is initiated by approval.
 57. A method according to claim 41 wherein installation of said updateable component is performed automatically without intervention.
 58. A method according to claim 41 wherein installation of said updateable component is initiated by approval.
 59. A method according to claim 1 wherein said digital content is split into said separate inputs in a relatively trusted server, said server is operable to deliver said digital content to said relatively trusted environment in the form of said separate inputs.
 60. A method according to claim 59 wherein said digital content arrives in the form of second separate inputs different from said first separate inputs to said relatively trusted server, said relatively trusted server is operable to rearrange said digital content to the form of said first separate inputs.
 61. A method according to claim 1 wherein said digital content arrives in the form of said separate inputs to a server, said server is operable to deliver said digital content to said relatively trusted environment in the form of said separate inputs.
 62. A method for secure distribution of digital content comprising the steps of: gathering input from at least one source; producing trustworthiness credentials about said digital content's intended recipient environment based on said input; evaluate said intended recipient environment's trustworthiness credentials; determine a distribution policy according to said trustworthiness credentials evaluation, and performing decisions about said distribution according to said policy.
 63. A method according to claim 62 wherein said digital content is a document.
 64. A method according to claim 62 wherein said digital content is multimedia digital content.
 65. A method according to claim 64 wherein said multimedia digital content is an audio digital content.
 66. A method according to claim 64 wherein said multimedia digital content is a video digital content.
 67. A method according to claim 64 wherein said multimedia digital content consists of at least two different streams.
 68. A method according to claim 62 wherein said credentials comprise geo-location information.
 69. A method according to claim 62 wherein said credentials comprise geo-location authentication level information.
 70. A method according to claim 62 wherein said credentials comprise authentication level information.
 71. A method according to claim 62 wherein said credentials comprise information gathered in the past.
 72. A method according to claim 71 wherein said credentials further comprise information gathered from analysis of said information gathered in the past.
 73. A method according to claim 71 wherein said information gathered in the past comprise of usage information.
 74. A method according to claim 62 wherein said credentials comprise of information about the environment into which said digital content is to be distributed.
 75. A method according to claim 74 wherein said information about the environment into which said digital content is to be distributed comprise of information about the software environment into which said digital content is distributed.
 76. A method according to claim 74 wherein said information about the environment into which said digital content is to be distributed comprise of information about the hardware environment into which said digital content is distributed.
 77. A method according to claim 76 wherein said information about the hardware environment into which said digital content is to be distributed comprise information about the video output hardware in that environment.
 78. A method according to claim 76 wherein said information about the hardware environment into which said digital content is to be distributed comprise information about the sound output hardware in that environment.
 79. A method according to claim 74 wherein said information about the environment into which said digital content is to be distributed comprise of information about the firmware environment into which said digital content is to be distributed.
 80. A method according to claim 62 wherein said credentials comprise of reports from at least one relatively trusted component.
 81. A method according to claim 80 wherein at least one of said components reside in the consumer's computer.
 82. A method according to claim 80 wherein at least one of said components is connected to the consumer's computer.
 83. A method according to claim 80 wherein at least one of said components is a software component.
 84. A method according to claim 80 wherein at least one of said components is a firmware component.
 85. A method according to claim 80 wherein at least one of said components is a tamper resistant component.
 86. A method according to claim 80 wherein at least one of said components is a hardware component.
 87. A method according to claim 83 wherein at least one of said software components is updateable.
 88. A method according to claim 84 wherein at least one of said firmware components is updateable.
 89. A method according to claim 62 wherein said method comprise of using at least one updateable component.
 90. A method according to claim 89 wherein said updateable component is associated with a revision level identifier.
 91. A method according to claim 90 wherein said revision level identifier is a version number.
 92. A method according to claim 90 wherein said revision level identifier is revision date.
 93. A method according to claim 90 wherein at least one aspect of operation of the underlying system depends on said revision level.
 94. A method according to claim 93 wherein at least some functionality of the underlying system is limited if said revision level does not belong to a specific set of revision levels.
 95. A method according to claim 94 wherein said limited functionality comprise of the ability to receive a set of digital content.
 96. A method according to claim 94 wherein said limited functionality comprise of the ability to receive a set of digital content in a specific format.
 97. A method according to claim 94 wherein said limited functionality comprise of the ability to receive a set of digital content in a specific method.
 98. A method according to claim 90 wherein said revision level is communicated to at least one other component of the underlying system by said updateable component.
 99. A method according to claim 98 wherein said communication is initiated by said updateable component.
 100. A method according to claim 98 wherein said communication is part of another communication that is part of the normal workflow of the underlying system.
 101. A method according to claim 98 wherein said communication is initiated by said other component of the underlying system.
 102. A method according to claim 89 wherein a component within said untrusted environment queries another component in the underlying system for revisioned version of said updateable component.
 103. A method according to claim 89 wherein transfer of said updateable component is performed automatically without intervention.
 104. A method according to claim 89 wherein transfer of said updateable component is initiated by approval.
 105. A method according to claim 89 wherein installation of said updateable component is performed automatically without intervention.
 106. A method according to claim 89 wherein installation of said updateable component is initiated by approval.
 107. A method according to claim 89 wherein said credentials comprise of said revision level.
 108. A method for secure distribution of digital content comprising the steps of: transferring digital media to an untrusted environment; using a relatively trusted environment within said untrusted environment operable to receive said digital content said relatively trusted environment comprises of mechanisms to restrict tampering with said relatively trusted environment.
 109. A method according to claim 108 wherein said relatively trusted environment comprise at least two components.
 110. A method according to claim 109 wherein said components comprise at least one hardware component.
 111. A method according to claim 109 wherein said components comprise at least one software component.
 112. A method according to claim 109 wherein said components comprise at least one firmware component.
 113. A method according to claim 108 wherein said relatively trusted environment is a hardware component.
 114. A method according to claim 108 wherein said relatively trusted environment is a firmware component.
 115. A method according to claim 108 wherein said relatively trusted environment is a software component.
 116. A method according to claim 109 wherein said components comprise a watchdog component wherein said watchdog component is capable of monitoring other components of the relatively trusted environment.
 117. A method according to claim 116 wherein said monitoring comprise of authentication.
 118. A method according to claim 117 wherein said authentication comprise authentication of a certificate.
 119. A method according to claim 118 wherein said certificate is a cryptographic certificate.
 120. A method according to claim 117 wherein said authentication comprise authentication of the code of the component.
 121. A method according to claim 120 wherein said authentication of the code of the component comprises calculating a derivative of said code.
 122. A method according to claim 120 wherein said authentication of the code of the component comprises analysis of the potential operation of said code.
 123. A method according to claim 117 wherein said authentication comprise of a challenge-response method which comprise of a step in which said watchdog component queries the authenticated component issuing a input and further comprises of a later step in which the authenticated component issue an output to the watchdog said output dependent on said input and said authentication is based on the correctness of said output depending on said input.
 124. A method according to claim 116 wherein said monitoring comprises monitoring of the operation of said components.
 125. A method according to claim 124 wherein said monitoring of the operation of said components comprise monitoring of used interfaces.
 126. A method according to claim 125 wherein said monitoring of used interfaces comprise monitoring of used operating system calls.
 127. A method according to claim 125 wherein said monitoring of used interfaces comprise monitoring of file operations.
 128. A method according to claim 125 wherein said monitoring of used interfaces comprise monitoring of memory operations.
 129. A method according to claim 125 wherein said monitoring of used interfaces comprise monitoring of communication operations.
 130. A method according to claim 125 wherein said monitoring of used interfaces comprise monitoring of driver operations.
 131. A method according to claim 125 wherein said monitoring of used interfaces comprise monitoring of input operations.
 132. A method according to claim 125 wherein said monitoring of used interfaces comprise monitoring of output operations.
 133. A method according to claim 125 wherein said monitoring of used interfaces comprise monitoring of interfaces used by interfaced entities.
 134. A method according to claim 108 wherein said relatively trusted environment comprise at least one updateable component.
 135. A method according to claim 134 wherein said updateable component is associated with a revision level identifier.
 136. A method according to claim 135 wherein said revision level identifier is a version number.
 137. A method according to claim 135 wherein said revision level identifier is revision date.
 138. A method according to claim 135 wherein at least one aspect of operation of the underlying system depends on said revision level.
 139. A method according to claim 138 wherein at least some functionality of the underlying system is limited if said revision level does not belong to a specific set of revision levels.
 140. A method according to claim 139 wherein said limited functionality comprise of the ability to receive a set of digital content.
 141. A method according to claim 139 wherein said limited functionality comprise of the ability to receive a set of digital content in a specific format.
 142. A method according to claim 139 wherein said limited functionality comprise of the ability to receive a set of digital content in a specific method.
 143. A method according to claim 135 wherein said revision level is communicated to at least one other component of the underlying system by said updateable component.
 144. A method according to claim 143 wherein said communication is initiated by said updateable component.
 145. A method according to claim 143 wherein said communication is part of another communication that is part of the normal workflow of the underlying system.
 146. A method according to claim 143 wherein said communication is initiated by said other component of the underlying system.
 147. A method according to claim 134 wherein a component within said untrusted environment queries another component in the underlying system for revisioned version of said updateable component.
 148. A method according to claim 134 wherein transfer of said updateable component is performed automatically without intervention.
 149. A method according to claim 134 wherein transfer of said updateable component is initiated by approval.
 150. A method according to claim 134 wherein installation of said updateable component is performed automatically without intervention.
 151. A method according to claim 134 wherein installation of said updateable component is initiated by approval.
 152. A method according to claim 109 wherein at least one of said components comprise of functionality to monitor at least one of its interfaces.
 153. A method according to claim 152 wherein said monitoring comprise of authentication.
 154. A method according to claim 153 wherein said authentication comprise authentication of a certificate.
 155. A method according to claim 154 wherein said certificate is a cryptographic certificate.
 156. A method according to claim 153 wherein said authentication comprise of a challenge-response method which comprise of a step in which said component queries the interfaced entity issuing a input and further comprises of a later step in which the interfaced entity issue an output to said component said output dependent on said input and said authentication is based on the correctness of said output depending on said input.
 157. A method according to claim 108 wherein said method comprises of functionality to monitor at least one of the interfaces used by the underlying system.
 158. A method according to claim 157 wherein said monitoring comprise of authentication.
 159. A method according to claim 158 wherein said authentication comprise authentication of a certificate.
 160. A method according to claim 159 wherein said certificate is a cryptographic certificate.
 161. A method according to claim 158 wherein said authentication comprise of a challenge-response method which comprise of a step in which the interfaced entity is queried by issuing a input and further comprises of a later step in which the interfaced entity issue back an output said output dependent on said input and said authentication is based on the correctness of said output depending on said input.
 162. A method according to claim 108 wherein said digital content arrives into said relatively trusted environment in a cryptographically encrypted format.
 163. A method according to claim 116 wherein information gathered from monitoring by at least one component is transferred to said watchdog component by said component.
 164. A method according to claim 163 wherein information gathered by said watchdog component is transferred as credentials information to a credentials based decision making mechanism.
 165. A method according to claim 116 wherein information gathered by said watchdog component is transferred as credentials information to a credentials based decision making mechanism.
 166. A method according to claim 108 wherein said relatively trusted environment comprise mechanism to restrict coping of at least one of the outputs said relatively trusted environment generates.
 167. A method according to claim 166 wherein said output is part of an internal interface.
 168. A method according to claim 166 wherein said output is an external output.
 169. A method according to claim 168 wherein said external output is sound output.
 170. A method according to claim 168 wherein said external output is video output.
 171. A method according to claim 168 wherein said external output is analog output.
 172. A method according to claim 171 wherein said analog output is analog sound output.
 173. A method according to claim 171 wherein said analog output is analog video output.
 174. A method according to claim 166 wherein said mechanism to restrict coping comprise of altering the output in order to change a quality of the copy which is produced by said copying.
 175. A method according to claim 174 wherein said quality of said copy is the observable quality of the copy.
 176. A method according to claim 174 wherein said change of said quality is to adversely effect said quality.
 177. A method according to claim 174 wherein said copying is digital copying.
 178. A method according to claim 174 wherein said copying is non-digital copying.
 179. A method according to claim 174 wherein said copying is digital copying which involves a non-digital transition. 